草庐IT

Java String.split 内存泄漏?

全部标签

asp.net-mvc - 如何将内存中的 xml 文档作为附件流式传输到 asp.net mvc 站点

我认为MVC应该让这一切变得更容易,但我正在尝试各种方法并遇到问题。如果我尝试接受这个问题的答案(相应地更改内容类型)...HowtocreatefileandreturnitviaFileResultinASP.NETMVC?...我遇到了麻烦,因为我在xml文件中的编码是UTF-16。我得到的错误是:不支持从当前编码切换到指定编码。这表明我需要在某处告诉MVC我想要UTF-16。或者,我想要一种使用二进制而不是文本的不同方法。 最佳答案 这就是我要解决的问题:publicFileStreamResultDownloadXML()

c - xmlCopyNode (libxml2) 内存泄漏?

我在C/Linux上使用libxml2从xml文件中提取信息。我创建了一个函数来查找某个标记的第一次出现并返回该标记的副本。例如给定以下xml文本:FirstoccurrenceoftagbChildnodeSecondoccurrenceoftagb我想提取第一个标签,如果存在,则包含所有子标签。这是我使用的代码的简化版本:#include#include#include#include#include#ifdefLIBXML_TREE_ENABLEDstaticintxml_extract_first_occurrence_by_name(xmlNode*start_node,xm

c# - "Root element not found"- 读取内存流时

我有一个存储在列表中的类。我连载它...XmlDocumentxd=newXmlDocument();MemoryStreamms=newMemoryStream();XmlSerializerxm=newXmlSerializer(typeof(List));xm.Serialize(ms,_bugs);StreamReadersr=newStreamReader(ms);stringstr=sr.ReadToEnd();xd.Load(ms);我查看了str并发现它是空的,但是该集合有一个对象。对于为什么会发生这种情况有什么想法吗? 最佳答案

c# - 在不加载到内存的情况下处理 xml

如果我不能将整个文件加载到内存中,那么处理XML的最佳方法是什么? 最佳答案 使用XmlReader并逐个元素地处理。 关于c#-在不加载到内存的情况下处理xml,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5547119/

java - 在 30GB XML 数据集上搜索正则表达式模式。使用16GB内存

我目前有一个JavaSAX解析器,它正在从一个30GB的XML文件中提取一些信息。目前是:读取每个XML节点将其存储到一个字符串对象中,在字符串上运行一些正则表达式将结果存入数据库对于数百万个元素。我在具有16GB内存的计算机上运行它,但内存没有得到充分利用。有没有一种简单的方法可以从输入文件中动态“缓冲”大约10gb的数据?我怀疑我可以手动采用“生产者”“消费者”多线程版本(在一侧加载对象,使用它们并在另一侧丢弃),但是该死的,XML现在很古老,没有有效的库吗紧缩他们? 最佳答案 简单说一下,Java可以使用您的16GB内存吗?您

c - R XML - 无法从内存中删除内部 C 节点

我必须解析大约2000个xml文档,从每个文档中提取某些节点,将它们添加到单个文档中,然后保存。我正在使用内部C节点,以便我可以使用XPath。问题是,当我遍历文档时,我无法从内存中删除内部C对象,最终使用了>4GB的内存。我知道问题不在于加载的树(我只是通过加载和删除每个文档的哈希树来运行循环),而在于过滤的节点或根节点。这是我使用的代码。我缺少什么以便在每次迭代结束时清除内存?xmlDoc谢谢你的帮助 最佳答案 所以我发现没有办法使用“XML”来做到这一点而不会出现内存泄漏和大量处理时间。幸运的是,“xml2”现在可以处理创建文

c# - 如何有效地使用内存附加到 C# 中的大型 XML 文件

有什么方法可以合并两个XmlDocument而无需在内存中保留第一个?我必须循环遍历多达一百个大型(~300MB)XML文件的列表,每个文件最多附加1000个节点,重复整个过程几次(因为新节点列表被清除以节省内存)。目前我加载了整个XmlDocument在添加新节点之前先写入内存,目前这是不可行的。您认为解决此问题的最佳方法是什么?我有一些想法,但我不确定哪个是最好的:永远不要加载整个XMLDocument,而不是使用XmlReader和XmlWriter同时写入随后重命名的临时文件。制作XmlDocument仅适用于新节点,然后手动将其写入现有文件(即file.WriteLine("

xml - 使用 Perl XML::Twig 处理程序处理大文件的内存使用效率低下

我偶尔需要从大型XML数据库导出中提取数据。文件大小在600到700MB之间。经过几天的研究,我得出结论XML::Twig是要走的路,因为它的处理程序允许我逐块处理文件。我按照示例进行操作,经过数小时的反复试验,我编写了执行我需要完成的工作的Perl代码。代码有效,它提取了我想要的数据并计算了我需要的细节。但是在运行脚本时(处理620MB的XML需要大约15分钟),我在事件监视器中注意到,到最后内存使用率迅速增加到不合理的高水平。我删除了处理我感兴趣的XML标签的Perl代码,并用一条指令替换它来增加一个变量,只需计算product的数量。元素已被发现。内存使用情况类似。首先是正常的,

xml - 用于转换大型 XML 文件的内存高效 XSLT

这个问题与arecentanswerby有关michael.hor257k,它又与ananswerby相关迪米特雷·诺瓦切夫。当使用上述答案中的样式表时(来自michael.hor257k),对于大型XML(大约60MB,示例XML如下所示),转换成功进行。当尝试另一个样式表时,它与michael.hor257k的有点不同,目的是将元素(带有子sectPr)和它们的后续兄弟元素(直到下一个带有childsectPr),递归地(即将元素分组到输入XML的深度)。示例输入XML:我试过的样式表:出于好奇,我在转换大约60MB的XML时遇到了OutOfMemoryError。我想知道,我想我

c# - XML序列化和反序列化与内存流

这个问题在这里已经有了答案:Rootelementismissing(7个答案)关闭7年前。以下代码在尝试反序列化代码时找不到根元素时出现错误:Anexceptionoftype'System.InvalidOperationException'occurredinSystem.Xml.dllbutwasnothandledinusercodeAdditionalinformation:ThereisanerrorinXMLdocument(0,0).Innerexception:{"Rootelementismissing."}代码看起来很简单,但是在这个问题上谷歌搜索和搜索SO并没